home *** CD-ROM | disk | FTP | other *** search
- class classes.enemy.DroidC
- {
- var x;
- var y;
- var moveScript;
- var matrixCoords;
- var id;
- var form;
- var clip;
- var advanceMax;
- var advanceMax2;
- var matrixVar;
- var colorR;
- var trans;
- var colorTrans;
- var dir;
- var f2;
- var ac;
- var ep;
- var axis;
- var xDest;
- var yDest;
- var oldDir;
- var xMov = 0;
- var yMov = 0;
- var xmt = 0;
- var ymt = 0;
- var xMovT = 0;
- var yMovT = 0;
- var speedOrig = 9;
- var speed = 9;
- var xDestMet = false;
- var yDestMet = false;
- var c = 0;
- var feelerInfo = [[-400,0,400,40],[0,0,400,40],[0,-400,40,400],[0,0,40,400]];
- var dirArray = ["L","R","U","D"];
- var life = 10;
- var nc = 0;
- var xA = 0;
- var yA = 0;
- var nudging = false;
- var dummyPlanted = false;
- var power = 20;
- var Name = "droidC";
- function DroidC(px, py, pmoveScript, pmatrixCoords, pform, pid)
- {
- this.x = px;
- this.y = py;
- this.moveScript = pmoveScript.slice();
- this.matrixCoords = pmatrixCoords.slice();
- this.id = pid;
- this.form = pform.slice();
- _root.d = _root.d + 1;
- this.clip = _root.attachMovie("droidC","droidC" + this.id + "Clip",_root.d + 50000);
- this.clip._x = this.x;
- this.clip._y = this.y;
- this.speed *= _root.dif.speed;
- this.speedOrig = this.speed;
- this.life *= _root.dif.life;
- this.advanceMax = 60 / (this.speed / 2);
- this.advanceMax2 = 50 / (this.speed / 2);
- if(this.matrixCoords[0] == "free")
- {
- this.matrixVar = 0;
- }
- else
- {
- this.matrixVar = 1;
- }
- this.speedVar();
- this.colorR = _root.randRange(-30,30);
- this.trans = new flash.geom.Transform(this.clip);
- this.colorTrans = new flash.geom.ColorTransform(1,1,1,1,this.colorR,this.colorR,this.colorR,0);
- this.trans.colorTransform = this.colorTrans;
- this.parseMoveScript();
- _root.stats.created = _root.stats.created + 1;
- }
- function broBehind()
- {
- this.dir = _root.advanceDir;
- }
- function bombed(num)
- {
- this.f2 = "death";
- }
- function nudge(pxA, pyA, pscale)
- {
- this.nc = 0;
- this.nudging = true;
- var _loc2_ = pscale / 100;
- this.xA = pxA * _loc2_;
- this.yA = pyA * _loc2_;
- }
- function missleCreep()
- {
- this.matrixVar = 0;
- this.dummyPlanted = true;
- _root.d = _root.d + 1;
- _root["dummy" + this.id] = new classes.misc.Dummy(this.x,this.y,this.id);
- _root.addEnemyShot("dummy" + this.id);
- this.clip.body.flame.gotoAndPlay("advance");
- this.ac = 0;
- this.ep = _root.randRange(20,60);
- this.speed /= 2;
- this.yMovT = 0;
- this.xMovT = this.dir != "L" ? this.speed : -1 * this.speed;
- this.f2 = "missleSeq";
- }
- function missleSeq()
- {
- this.ac = this.ac + 1;
- if(this.ac == this.ep)
- {
- if(this.dir == "L")
- {
- var _loc6_ = 6;
- var _loc10_ = 18;
- }
- else if(this.dir == "R")
- {
- _loc6_ = 0;
- _loc10_ = 18;
- }
- else if(this.dir == "U")
- {
- _loc6_ = 6;
- _loc10_ = 6;
- }
- else
- {
- _loc6_ = 18;
- _loc10_ = 0;
- }
- _root.enemyShotID = _root.enemyShotID + 1;
- _root["droidCMissle" + _root.enemyShotID] = new classes.shots.DroidCMissle(this.x + _loc6_,this.y + _loc10_,this.dir,_root.enemyShotID);
- _root.addEnemyShot("droidCMissle" + _root.enemyShotID);
- this.xMovT = 0;
- _root.audio.playLevel3("droidCMissle2",_root.randRange(22,33));
- }
- if(this.ac == this.ep + 3)
- {
- this.clip.body.gotoAndPlay("flip");
- }
- if(this.ac == this.ep + 11)
- {
- this.speed = this.speedOrig;
- this.dir = this.dir != "L" ? "L" : "R";
- this.axis = "x";
- this.xMovT = this.dir != "L" ? this.speed : -1 * this.speed;
- this.clip.body.gotoAndStop("main");
- this.clip.body.flame.gotoAndPlay("startMain");
- var _loc5_ = _root.advanceDir != "L" ? "L" : "R";
- var _loc4_ = random(2) != 1 ? "D" : "U";
- var _loc9_ = _loc4_ != "U" ? "U" : "D";
- var _loc7_ = _root.randRange(20,50);
- var _loc3_ = !(this.y < 150 && this.y > 450) ? _root.randRange(80,150) : _root.randRange(100,300);
- var _loc8_ = !(this.x < 700 && this.x > 300) ? _root.randRange(80,150) : _root.randRange(100,300);
- this.moveScript = [_loc5_,_loc7_,_loc4_,_loc3_,_loc5_,_loc8_,_loc9_,_loc3_,"return"];
- this.parseMoveScript();
- }
- }
- function gotoMatrix2()
- {
- this.xDest = _root["dummy" + this.id + "Clip"]._x;
- if(Math.abs(this[this.axis + "Dest"] - this[this.axis]) < this.speed + 1)
- {
- if(this.axis == "x")
- {
- this.x = this.xDest;
- }
- else
- {
- this.y = this.yDest;
- }
- this[this.axis + "MovT"] = 0;
- this.axis = this.axis != "x" ? "x" : "y";
- this[this.axis + "MovT"] = this[this.axis + "Dest"] <= this[this.axis] ? -1 * this.speed : this.speed;
- this.getDirString();
- this.speed = this.speedOrig;
- }
- if(Math.abs(this.x - this.xDest) < this.speed + 1 && Math.abs(this.y - this.yDest) < this.speed + 1)
- {
- this.x = this.clip._x = this.xDest;
- this.y = this.clip._y = this.yDest;
- this.xMovT = this.xMov = 0;
- this.yMovT = this.yMov = 0;
- this.matrixVar = 2;
- if(this.dummyPlanted)
- {
- _root.removeEnemyShot("dummy" + this.id);
- this.dummyPlanted = false;
- }
- this.dir = _root.advanceDir;
- this.clip.body.flame.gotoAndPlay("still");
- this.f2 = "wait";
- }
- }
- function speedVar()
- {
- if(random(3) == 1)
- {
- this.speed *= _root.randRange2(0.9999,1.0001);
- }
- }
- function parseMoveScript()
- {
- this.dir = this.moveScript[0];
- if(this.dir == "break")
- {
- delete this.moveScript;
- this[this.axis + "MovT"] = 0;
- if(this.matrixCoords[0] == "free")
- {
- this.f2 = "wander";
- this.axis = random(10) <= 4 ? "y" : "x";
- this[this.axis + "MovT"] = random(2) <= 0 ? -1 * this.speed : this.speed;
- this.speedVar();
- this.getDirString();
- }
- else
- {
- this.xDest = _root.advanceDir != "L" ? this.matrixCoords[0] * 60 : this.matrixCoords[0] * 60 + 320;
- this.yDest = this.matrixCoords[1] * 50 + 10;
- this.axis = Math.abs(this.xDest - this.x) <= Math.abs(this.yDest - this.y) ? "y" : "x";
- this[this.axis + "MovT"] = this[this.axis + "Dest"] <= this[this.axis] ? -1 * this.speed : this.speed;
- this.getDirString();
- this.speedVar();
- this.f2 = "gotoMatrix";
- }
- }
- else if(this.dir == "return")
- {
- this.xDest = _root["dummy" + this.id + "Clip"]._x;
- this.yDest = _root["dummy" + this.id + "Clip"]._y;
- this[this.axis + "MovT"] = 0;
- this.axis = Math.abs(this.xDest - this.x) <= Math.abs(this.yDest - this.y) ? "y" : "x";
- this[this.axis + "MovT"] = this[this.axis + "Dest"] <= this[this.axis] ? -1 * this.speed : this.speed;
- this.getDirString();
- this.speedVar();
- this.f2 = "gotoMatrix2";
- }
- else
- {
- this[this.axis + "MovT"] = 0;
- this.f2 = "gotoXYDest";
- this.axis = !(this.dir == "L" || this.dir == "R") ? "y" : "x";
- this[this.axis + "MovT"] = !(this.dir == "L" || this.dir == "U") ? this.speed : -1 * this.speed;
- this.speedVar();
- if(this.dir == "L" || this.dir == "U")
- {
- this[this.axis + "Dest"] = this[this.axis] - this.moveScript[1];
- }
- else
- {
- this[this.axis + "Dest"] = this[this.axis] + this.moveScript[1];
- }
- this.moveScript.splice(0,2);
- }
- }
- function gotoXYDest()
- {
- if(Math.abs(this[this.axis + "Dest"] - this[this.axis]) < this.speed + 1)
- {
- if(this.axis == "x")
- {
- this.x = this.xDest;
- }
- else
- {
- this.y = this.yDest;
- }
- this.parseMoveScript();
- }
- }
- function gotoMatrix()
- {
- if(Math.abs(this[this.axis + "Dest"] - this[this.axis]) < this.speed + 1)
- {
- if(this.axis == "x")
- {
- this.x = this.xDest;
- }
- else
- {
- this.y = this.yDest;
- }
- this[this.axis + "MovT"] = 0;
- this.axis = this.axis != "x" ? "x" : "y";
- this[this.axis + "MovT"] = this[this.axis + "Dest"] <= this[this.axis] ? -1 * this.speed : this.speed;
- this.getDirString();
- this.speed = this.speedOrig;
- }
- if(Math.abs(this.x - this.xDest) < this.speed + 1 && Math.abs(this.y - this.yDest) < this.speed + 1)
- {
- this.x = this.clip._x = this.xDest;
- this.y = this.clip._y = this.yDest;
- this.xMovT = this.xMov = 0;
- this.yMovT = this.yMov = 0;
- this.matrixVar = 2;
- this.dir = _root.advanceDir;
- this.clip.body.flame.gotoAndPlay("still");
- _root.matrixNum = _root.matrixNum + 1;
- if(_root.matrixNum >= _root.matrixSize)
- {
- _root.matrixComplete = true;
- }
- _root["formB" + this.form[0]] = "matrixed";
- this.f2 = "wait";
- }
- }
- function getDirString()
- {
- if(this.xMovT < -1)
- {
- this.dir = "L";
- }
- else if(this.xMovT > 1)
- {
- this.dir = "R";
- }
- else if(this.yMovT > 1)
- {
- this.dir = "D";
- }
- else if(this.yMovT < -1)
- {
- this.dir = "U";
- }
- }
- function evade()
- {
- if(this.matrixVar == 2)
- {
- this.missleCreep();
- }
- }
- function wait()
- {
- if(random(1000) >= 990 + _root.dif.wait * 2 && _root.matrixComplete)
- {
- this.dir = this.findDir();
- if(this.dir == _root.advanceDir)
- {
- if(random(15) > 2)
- {
- this.missleCreep();
- }
- else
- {
- this.ep = _root.randRange(20,80);
- this.ep *= 1 / _root.dif.speed;
- this.ac = 0;
- this.xMovT = _root.advanceDir != "L" ? 1.1 * this.speed : -1.1 * this.speed;
- this.clip.body.gotoAndPlay("attack");
- this.clip.body.face.gotoAndPlay("attack");
- this.clip.body.flame.gotoAndPlay("startAttack");
- this.f2 = "attacking";
- this.matrixVar = 0;
- }
- }
- else if(this.dir == "U" || this.dir == "D")
- {
- this.axis = !(this.dir == "L" || this.dir == "R") ? "y" : "x";
- this[this.axis + "MovT"] = !(this.dir == "L" || this.dir == "U") ? this.speed : -1 * this.speed;
- this.matrixVar = 0;
- this.c = 0;
- this.f2 = "leavingMatrix";
- this.clip.body.flame.gotoAndPlay("startMain");
- }
- else
- {
- this.dir = _root.advanceDir;
- }
- }
- }
- function leavingMatrix()
- {
- this.c = this.c + 1;
- if(this.c > this.advanceMax2)
- {
- this.c = 0;
- this.dir = this.findDir();
- if(this.dir == _root.advanceDir)
- {
- if(random(2) == 1)
- {
- this.missleCreep();
- }
- else
- {
- this.ep = _root.randRange(20,80);
- this.ep *= 1 / _root.dif.speed;
- this.ac = 0;
- this.yMovT = 0;
- this.xMovT = _root.advanceDir != "L" ? 1.1 * this.speed : -1.1 * this.speed;
- this.clip.body.gotoAndPlay("attack");
- this.clip.body.face.gotoAndPlay("attack");
- this.clip.body.flame.gotoAndPlay("attack");
- this.f2 = "attacking";
- }
- }
- }
- }
- function findDir()
- {
- _root.d = _root.d + 1;
- _root.attachMovie("feeler","feelerClip",_root.d);
- var _loc7_ = [];
- var _loc9_ = 0;
- var _loc11_ = this.dirArray.length;
- while(_loc9_ < _loc11_)
- {
- _root.feelerClip._x = this.x + this.feelerInfo[_loc9_][0];
- _root.feelerClip._y = this.y + this.feelerInfo[_loc9_][1];
- _root.feelerClip._width = this.feelerInfo[_loc9_][2];
- _root.feelerClip._height = this.feelerInfo[_loc9_][3];
- var _loc3_ = 0;
- var _loc8_ = _root.chars.length;
- var _loc6_ = false;
- while(_loc3_ < _loc8_)
- {
- var _loc5_ = _root.chars[_loc3_] + "Clip";
- if(_root.feelerClip.hitTest(_root[_loc5_]))
- {
- var _loc4_ = _root.chars[_loc3_];
- if(_root[_loc4_].matrixVar == 2 && _loc4_ != this.Name + this.id)
- {
- _loc6_ = true;
- break;
- }
- }
- _loc3_ = _loc3_ + 1;
- }
- if(!_loc6_)
- {
- var _loc10_ = _root.advanceDir != "L" ? "L" : "R";
- if(this.dirArray[_loc9_] != _loc10_)
- {
- _loc7_.push(this.dirArray[_loc9_]);
- }
- }
- _loc9_ = _loc9_ + 1;
- }
- _loc9_ = 0;
- _loc11_ = _loc7_.length;
- if(_loc9_ < _loc11_)
- {
- if(_loc7_[_loc9_] == _root.advanceDir)
- {
- return _root.advanceDir;
- }
- return _loc7_[random(_loc7_.length)];
- }
- }
- function attacking()
- {
- this.ac = this.ac + 1;
- this.xMovT *= 1.01;
- this.yMovT *= 1.01;
- this.speed *= 1.01;
- if(this.ac == this.ep)
- {
- this[this.axis + "MovT"] = 0;
- this.axis = this.axis != "x" ? "x" : "y";
- this[this.axis + "MovT"] = random(2) <= 0 ? -1 * this.speed : this.speed;
- this.getDirString();
- this.ac = 0;
- this.ep = _root.randRange(20,80);
- }
- }
- function death()
- {
- _root.stats.destroyed = _root.stats.destroyed + 1;
- _root.stats.score += 5000;
- if(this.matrixVar == 1)
- {
- _root.matrixNum = _root.matrixNum + 1;
- if(_root.matrixNum >= _root.matrixSize)
- {
- _root.matrixComplete = true;
- }
- }
- _root.powerUp(this.x,this.y,94);
- if(this.dummyPlanted)
- {
- _root.removeEnemyShot("dummy" + this.id);
- this.dummyPlanted = false;
- }
- var _loc3_ = 0;
- var _loc4_ = _root["form" + this.form[0]].length;
- while(_loc3_ < _loc4_)
- {
- if(_root["form" + this.form[0]][_loc3_] == "droidC" + this.id)
- {
- _root["form" + this.form[0]].splice(_loc3_,1);
- if(_root["form" + this.form[0]].length == 0)
- {
- delete _root["form" + this.form[0]];
- delete _root["formB" + this.form[0]];
- if(_root["formB" + this.form[0]] == "matrixed")
- {
- _loc3_ = 0;
- _loc4_ = random(2) + 1;
- while(_loc3_ < _loc4_)
- {
- _root.createPowerUp([this.x,this.y,"coin5"]);
- _loc3_ = _loc3_ + 1;
- }
- _root.stats.score += 5000;
- }
- else
- {
- _loc3_ = 0;
- _loc4_ = random(2) + 2;
- while(_loc3_ < _loc4_)
- {
- _root.createPowerUp([this.x,this.y,"coin5"]);
- _loc3_ = _loc3_ + 1;
- }
- _root.stats.score += 10000;
- }
- delete _root["formB" + this.form[0]];
- }
- break;
- }
- _loc3_ = _loc3_ + 1;
- }
- _root.createExploA([this.x + this.clip._width / 2,this.y + this.clip._height / 2,_root.randRange(80,130),_root.randRange(75,100)],"Yellow");
- _loc3_ = 0;
- _loc4_ = random(3);
- while(_loc3_ < _loc4_)
- {
- _root.createShrapnel([this.x + this.clip._width / 2,this.y + this.clip._height / 2,"droidC","Yellow"]);
- _loc3_ = _loc3_ + 1;
- }
- _root.createEnemySoul([this.x + this.clip._width / 2,this.y + this.clip._height / 2,"red"]);
- _root.audio.playLevel4("droidX" + (random(3) + 1),_root.randRange(22,33));
- _root.removeChar("droidC" + this.id);
- this.f2 = "";
- }
- function advance()
- {
- this.dir = _root.advanceDir;
- this.clip.body.flame.gotoAndPlay("advance");
- this.xMovT = _root.advanceDir != "L" ? 1 * (this.speed / 2) : -1 * (this.speed / 2);
- this.f2 = "advancing";
- }
- function advancing()
- {
- this.c = this.c + 1;
- if(this.c > this.advanceMax)
- {
- this.xMovT = 0;
- this.c = 0;
- this.f2 = "wait";
- _root.d = _root.d + 1;
- _root.attachMovie("sight","sightClip",_root.d);
- _root.sightClip.gotoAndStop("hindSight");
- _root.sightClip._x = this.x;
- _root.sightClip._y = this.y;
- _root.sightClip._rotation = 0;
- if(_root.advanceDir == "L")
- {
- _root.sightClip._rotation = 180;
- }
- if(_root.sightClip.hitTest(_root[_root.char].x,_root[_root.char].y,true))
- {
- _root.broBehind();
- }
- removeMovieClip(_root.sightClip);
- }
- }
- function wander()
- {
- if(random(100) > 98 + _root.dif.wander)
- {
- this[this.axis + "MovT"] = 0;
- this.axis = this.axis != "x" ? "x" : "y";
- this[this.axis + "MovT"] = random(2) <= 0 ? -1 * this.speed : this.speed;
- this.getDirString();
- }
- }
- function death2()
- {
- _root.removeChar("droidC" + this.id);
- this.f2 = "";
- }
- function main()
- {
- this[this.f2]();
- if(this.oldDir != this.dir)
- {
- this.clip.gotoAndStop("fly" + this.dir);
- }
- this.oldDir = this.dir;
- if(this.nudging)
- {
- this.xA *= 0.5;
- this.yA *= 0.5;
- this.nc = this.nc + 1;
- var _loc8_ = 255 - this.nc * 17;
- this.colorTrans.blueOffset = _loc8_;
- this.trans.colorTransform = this.colorTrans;
- if(this.nc == 15)
- {
- this.xA = this.yA = 0;
- this.nudging = false;
- this.colorTrans.blueOffset = this.colorR;
- this.trans.colorTransform = this.colorTrans;
- }
- }
- var _loc4_ = 0;
- var _loc7_ = _root.broShots.length;
- while(_loc4_ < _loc7_)
- {
- var _loc6_ = _root.broShots[_loc4_] + "Clip";
- if(this.clip.hitTest(_root[_loc6_]))
- {
- var _loc3_ = _root.broShots[_loc4_];
- var _loc5_ = this.life;
- this.life -= _root[_loc3_].power;
- if(this.life < 1)
- {
- this.f2 = "death";
- }
- else
- {
- _root.audio.playLevel4("droidHit" + (random(2) + 1),_root.randRange(3,8));
- this.nudge(_root[_loc3_].xMov,_root[_loc3_].yMov,10);
- }
- _root[_root.char].fc = _root[_root.char].fireFreq - _root.rapidVar;
- _root[_loc3_].exploX = this.x + this.clip._width / 2;
- _root[_loc3_].exploY = this.y + this.clip._height / 2;
- _root[_loc3_].hit(_loc5_);
- break;
- }
- _loc4_ = _loc4_ + 1;
- }
- if(this.clip.hitTest(_root[_root.char + "Clip"]))
- {
- _root[_root.char].hit(this.xMov,this.yMov,100,this.power);
- this.f2 = "death";
- }
- if(this.x > 1050 || this.x < -50 || this.y < -50 || this.y > 650)
- {
- delete _root["form" + this.form[0]];
- delete _root["formB" + this.form[0]];
- if(this.dummyPlanted)
- {
- _root.removeEnemyShot("dummy" + this.id);
- this.dummyPlanted = false;
- }
- this.f2 = "death2";
- }
- if(this.xMovT < this.xMov)
- {
- this.xMov -= 1.5;
- }
- else if(this.xMovT > this.xMov)
- {
- this.xMov += 1.5;
- }
- else
- {
- this.xMov = this.xMovT;
- }
- if(this.yMovT < this.yMov)
- {
- this.yMov -= 1.5;
- }
- else if(this.yMovT > this.yMov)
- {
- this.yMov += 1.5;
- }
- else
- {
- this.yMov = this.yMovT;
- }
- this.x += this.xMov + this.xA;
- this.y += this.yMov + this.yA;
- this.clip._x = this.x;
- this.clip._y = this.y;
- }
- }
-